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(57) Abstract 



The present invention is directed to a system, method, and apparatus for adding the benefit of object-oriented programming to 
conforming application programs to the specifications of telephony software interfaces and reducing the traffic load from messages generated 
and sent by line devices to application programs. An object-oriented interface layer is inserted between the application program which 
accepts objects from the application programs and causes the telephony software interface to perform a standard set of operations. From the 
standpoint of the telephony software interface, the object-oriented interface layer is the application program utilizing the line devices, thus 
causing the line devices to generate a single message to the object-oriented interface layer which distributes the message to the appropriate 
application programs. Accordingly, the traffic load caused by the generation of messages is reduced. 
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MULTI-CLIENT OBJECT-ORIENTED INTERFACE LAYER 

BACKGROUND OF THE INVENTION 

Technical Field of the Invention 
5 The present invention is related to telephony software interface, and more 

particularly, to adding the benefit of object-oriented programming and distributed 
computing to the telephony software interface. 

Description of Related Art 

10 Advances in computers systems have greatly simplified the task of 

information processing. Computer systems can typically store large amounts of 
information in a relatively small area of physical space and permit the information 
stored to be easily accessed and modified. Computer systems also allow large 
amounts of information to be processed both quickly and accurately. 

15 Computer systems are sometimes operated as stand-alone devices or 

connected together by way of network connections, typically together with a 
server, to form a computer network. When networked together, the resources of 
each computer can be used together to perform an information processing function. 
The foregoing is known as distributed computing. A server is a class of computers 

20 used to handle file, print, and certain application services which are common to all 
the connected computers, known as clients. A common use of the server also 
includes handling and maintaining telephony equipment for use by the clients. 
Handling and maintaining the telephony equipment at the server is advantageous 
because the same telephony equipment can be used by any of the clients which can 

25 be sparsely located about a geographic area. 

Communication of information is one of the most popular uses of 
computers today. Computers connected across a communication channel or 
medium are able to transfer large amounts of data electronically. The data is 
generated by and used within application programs which cause computers to 
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perform useful functions such as word processing, browsing web pages, accessing 
databases, etc. 

There are several communication media that are available to users. One of 
the most common communications mediums for communication between - 
computers is the telephonic infrastructure. The telephonic infrastructure includes, 
but is not limited to, the public switched telephone network (PSTN), a private 
branch exchange (PBX), integrated services digital network (ISDN), and what is 
known as a Tl/El line. The foregoing are known in the art as line devices. A user 
can connect their computer to a line device, and then place a phone call to another 
computer similarly connected to the telephonic infrastructure. In the networking 
context, the user at a client can use a line device maintained by a server for 
communication. 

In order for data from application program to be transmitted using a 
particular line device, model-specific technical details of the particular line device 
must be known. The model-specific details of the line device can be hardcoded 
into the application program. However, because the application program is usually 
sold separately from the line device, the application program could potentially use 
any of several hundred different line device models. Therefore, programs specific 
to each potential line device would have to be included in the application program. 

An alternative approach is to abstract the model-specific technical details 
from the application program. A telephony software interface provides a standard 
interface to any number of application programs, wherein the application programs 
communicate a standardized set of commands through the interface to telephony 
software interface. Telephony software receives commands through the telephony 
software interface and uses a set of files containing the model-specific technical 
details to effectuate the requests of the application program. Because the model- 
specific technical details files are separated from the application program, the files 
can be provided with the line device. Therefore, only the model-specific technical 
details for the line devices used are installed in the computer. A key advantage to 
telephone software interfaces are that the application program and the telephony 
software can be executed on different computers. Therefore, the telephony 
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software at a server can be used to effectuate commands from an application 
program executed by a client. 

A very commonly used telephony software interface is the Telephony 
Application Programming Interface (TAPI) developed by the Microsoft - 
5 Corporation and the Intel Corporation. Another example of telephony software 
interface is the Telephony Services Application Programming Interface (TSAPI) 
developed by the Novell Corporation. In order for an application program to use a 
telephony software interface, the application program must conform to certain 
specifications of the telephony software interface. Conforming to the specifications 

10 of a telephony software interface is a cumbersome and tedious process where the 
telephony software interface is not object-oriented. Object-oriented programming 
is a form of software development that models the real world through 
representation of objects or modules that contain data as well as instructions that 
work upon that data. The objects encapsulate the attributes, relationships, and 

15 methods of software-identifiable program components simplifying complex 
programs. 

Additionally, in a networking context where the telephony software 
interface serves a number of application programs. As each application program 
conducts operations on the various line devices, the line devices send messages to 

20 the application programs. In many cases, several application programs 

simultaneously perform operation on a single line device. Where the line device 
requires communication to the application programs, a separate message is sent to 
each application program. Sending a separate message to each application 
program results in excess traffic within the telephony software interface. 

25 Accordingly, it would be beneficial if a way of adding object orientation to 

the telephony software interface as well reducing traffic generated from the 
messages could be devised. 



30 



SUMMARY OF THE INVENTION 

The present invention is directed to a system, method, and apparatus for 
transmitting information from an application program on a line device by receiving 
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an object from said application program at an object-oriented interface layer 
causing a telephony software interface to perform an operation corresponding to 
the object, receiving a message from the line device at the object-oriented interface 
layer, forwarding the message to the application program. - 

5 

BRIEF DESCRIPTION OF THE DRAWINGS 

A more complete understanding of the method and apparatus of the present 
invention may be acquired by reference to the following Detailed Description 
when taken in conjunction with the accompanying Drawings wherein: 
10 FIGURE 1 is a block diagram of the Telephony Application Programming 

Interface architecture; 

FIGURE 2 is an exemplary client/server environment for practicing the 
present invention; 

FIGURE 3 is an exemplary software architecture embodying the present 
15 invention; and 

FIGURE 4 is representative hardware environment for practicing the 
present invention. 

DETAILED DESCRIPTION OF PREFERRED EMBODIMENTS 

20 The numerous innovative teachings of the present application will be 

described with particular reference to the presently preferred exemplary 
embodiments. However, it should be understood that this class of embodiments 
provides only a few examples of the many advantageous uses of the innovative 
teachings herein. In general, statements made in the specification of the present 

25 application do not necessarily delimit any of the various claimed inventions. 

Moreover, some statements may apply to some inventive features but not to others. 

Referring now to FIGURE 1, a block diagram of the Telephony 
Application Programming Interface (TAPI) architecture is described. TAPI is a 
telephony software interface which provides a standard interface through which 

30 application programs 105 can access, transmit information on, and receive 
information from telephony hardware 110, known as line devices. Another 
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example of a telephony software interface includes Telephony Services 
Application Programming Interface (TSAPI). The application program 105 can 
be, for example, a word processor, a Web Browser, or a Chat Program. The 
telephony hardware 110 can include, for example, a modem connected to a PSTN 
5 line 115, an ISDN line 1 10b, or a private branch exchange (PBX) 1 10c. 

In order for information from application program 105 to be transmitted 
using a particular line device 110, model-specific technical details of the particular 
line device must be known. The model-specific details of the line device 110 can 
be hardcoded into the application program 105. However, because the application 

10 program 105 is usually sold separately from the line device 1 10, the application 
program 105 could potentially use any of several hundred different line device 
models. Therefore, programs specific to each potential line device 1 10 would have 
to be included in the application program 105. 

An alternative approach is to abstract the model-specific technical details 

15 from the application program 105. The TAPI architecture, as well as the TSAPI 
architecture, provide an interface to the line devices 1 10 which abstract the model- 
specific details of the line device from the application program 105. The TAPI 
architecture includes a telephony software interface dynamic link library (DLL) 
120, an executable program, TAPISRV 125, and one or more service providers 

20 130. The DLL 120 can comprise, for example, the dynamic link library known as 
"tapi.dll" or the dynamic link library known as "tapi32.dll " The DLL 120 
receives function requests from the application program 105 for the line device 
1 10, and transfers the function requests to TAPISRV 125 using the lightweight 
remote procedure call (LRPC). 

25 TAPISRV 125 is a telephony software interface executable program that 

provides the sequence of operations that exposes the line devices 1 10 to application 
programs 105 through a TAPI protocol and causes the line devices 1 10 to perform 
specific functions. The required model-specific technical details of the line device 
110 are stored in the service provider 130 for the line device 1 10. The service 

30 provider 130 is a file written by the manufacturers of the line device 1 10 which is 
installed with the line device 110. 
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The foregoing is advantageous because the application program 105 need 
not be aware of any of the specific details of the line device 110. Another 
advantage is that the application program 105 and the DLL 120 constitute a 
different process from TAPISRV 125. The process including the application - 
5 program 105 and the DLL 120 are referred to as the application process 135, while 
the process including TAPISRV 125 is referred to as the TAPISRV process 140. 
The separation of the processes 135, 140 is advantageous in a computer network 
where the processes may be performed on different computers. 

Referring now to FIGURE 2, an exemplary client/server environment for 

10 practicing the present invention is described. The application process 135 is 

executed by a client 205 and a TAPISRV process 140 executed on a server 210. 
The DLL 120 and TAPISRV 125 communicate over a client/server connection 215 
which may comprise an in-band or an out-of-band connection. 

In order for an application program 105 to use the DLL 120, the application 

15 program must conform to certain specifications of the DLL 120 and TAPISRV 
125. Conforming to the specifications of the DLL 120 and TAPISRV 125 is a 
cumbersome and tedious process because neither are object-oriented. Object- 
oriented programming is a form of software development that models the real 
world through representation of objects or modules that contain data as well as 

20 instructions that work upon that data. The objects encapsulate the attributes, 
relationships, and methods of software-identifiable program components, 
simplifying complex programs. 

Additionally, where the DLL 120 and TAPISRV 125 serve a number of 
application programs 105, more than one application program 105 may conduct 

25 operations on a line device 1 10. Responsive to certain events, the line device 110 
send messages to the application programs 105. Where the line device 1 10 
requires communication to the application programs 105, a separate message is 
generated and sent to each application program performing operations on the line 
device 110. Generating and sending a separate message to each application 

30 program 105 results in excess traffic within the telephony software interface. 
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The cumbersome and tedious task of conforming the application program 
105 to conform to the specifications of the DLL 120 and TAPISRV 125, as well as 
the traffic resulting from message routing are alleviated using a object-oriented 
interface layer. Referring now to FIGURE 3, an exemplary software architecture 
5 embodying the present invention is described. A server 210 maintains any number 
of line devices 1 10 available for use by application programs 105 executed by 
clients 205. A telephony software interface 305 provides a standard interface 
through which application programs 105 can access, transmit information on, and 
receive information from the available line devices 1 10. The telephony software 

10 interface can comprise, for example, TAPI which includes the DLL 120, 

TAPISRV 125, and necessary service providers 130, or TSAPI. An object- 
oriented interface layer 3 10 is inserted between the telephony software interface 
305 and each application program 105. The object-oriented interface layer 310 is 
an interface which establishes a session with the telephony software interface 305. 

15 During the session, the object-oriented interface layer 310 accepts objects from the 
application programs 105 and causes the telephony software interface 305 to 
perform a number of operations such as "Make Call", "Drop Call", "Hold", and 
"Transfer" . In one embodiment, the object-oriented interface layer 3 10 can 
comprise what is known as a Distributed Component Object Module (DCOM). 

20 Accordingly, the cumbersome task of conforming the application programs 105 to 
the specification of the telephony software interface is abstracted within the object- 
oriented interface layer 310. 

The utility of the object-oriented interface layer 3 10 is optimized by 
placing the object-oriented interface layer at the server. By placing the object- 

25 oriented interface layer 3 10 at the server 210, the object-oriented interface layer 
can be used by each of the application programs 105 on the various clients 205, 
To accommodate multiple application programs 105, the object-oriented interface 
layer 310 includes a management interface 315 which allows the application 
programs to register and unregister with the object-oriented interface layer 310. 

30 The management interface 3 1 5 also permits application programs 105 to open and 
close the line devices 1 10 controlled by the Telephony Software Interface 305. 
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The support for the operations by the telephony software interface 305 in the 
object-oriented interface layer 3 10 is separated from the management interface 315 
and maintained in a Device Interface 3 17. The management functions and the 
telephony software interface operation support are separated to further the object- 
5 oriented functionality of the object-oriented interface layer 310. 

From the standpoint of the Telephony Software Interface 305, the object- 
oriented interface layer 3 10 is the program utilizing line devices 110, even though 
application programs 105 are the programs which provide the information and data 
transmitted on the line devices. Accordingly, when a line device 110 needs to 
10 communicate information to the application program utilizing the line device, a 

single message is generated and directed towards the object-oriented interface layer 
310. Because the messages contain useful information for the application 
programs 105 utilizing the sending line device 1 10, the object-oriented interface 
layer 310 must distribute the message to the appropriate application programs. 
1 5 To distribute the messages generated by the line devices 1 1 0 to the 

appropriate application programs 105, the object-oriented interface layer includes a 
First Party Connection Point 320 and a Third Party Connection Point 325. The 
First Party Connection Point 320 is an interface for receiving messages for 
application programs 105 which generally involve individual line devices 110, 
20 known as first party applications. A message from a line device 110 that needs to 
be distributed to a first party application is routed to the First Party Connection 
Point 320 which forwards the message to the appropriate application program 105. 
The Third Party Connection Point 325 is an interface for receiving messages for 
application programs 105 which generally have global, system level perspective 
25 and involve most, if not all of the line devices 1 10, known as third party 
applications. Because third party applications have a global, system level 
perspective, messages from most, if not all of the line device 1 10 are relevant to 
the proper operation of the third party application. Accordingly, any message 
received by the object-oriented interface layer 310 from a line device 1 10 is routed 
30 to the Third Party Connection Point 325 . The Third Party Connection Point 325 
then broadcasts the message to every third party application. 
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It is noted that the interfaces for distributing messages to the application 
programs 105 are not limited to the First Party Connection Point 320 and the Third 
Party Connection Point 320. In fact, the object-oriented interface layer 3 10 is 
versatile such that other customized interfaces are easily incorporated by those - 
5 skilled in the art. 

Referring now to FIGURE 4, there is shown a representative hardware 
environment for a computer system 458, such as client 205 or server 210 for 
practicing the present invention. A CPU 460 is interconnected via system bus 462 
to random access memory (RAM) 464, read only memory (ROM) 466, an 

1 0 input/output (I/O) adapter 468, a user interface adapter 472, communications 
adapters 484, and a display adapter 486. The input/output (I/O) adapter 468 
connects peripheral devices such as hard disc drives 440, floppy disc drives 441 for 
reading removable floppy discs 442, and optical disc drives 443 for reading 
removable optical disc 444 (such as a compact disc or a digital versatile disc) to the 

1 5 bus 462. The user interface adapter 472 connects devices such as a keyboard 474, 
a mouse 476 having a plurality of buttons 467, a speaker 478, a microphone 482, 
and/or other user interfaces devices such as a touch screen device (not shown) to 
the bus 462. The display adapter 486 connects a monitor 488 to the bus 462. The 
communications adapters 484 connect the computer system to a data processing 

20 network 492. The data processing network 492 may include any number of other 
computer systems, such as another computer system 458 or a server, as well as 
mass storage elements such as another hard disc drive 440, or another optical disc 
drive 443 for reading optical discs 444. 

The object-oriented interface layer 3 1 0 can be implemented as sets of 

25 instructions resident in the random access memory 464 of one or more computer 
systems 458 configured generally as described in FIGURE 4. Until required by the 
computer system 458, the set of instructions may be stored in another computer 
readable memory, for example in a hard disc drive 440, or in removable memory 
such as an optical disc 444 for eventual use in an optical disc drive 443, or a floppy 

30 disc 442 for eventual use in a floppy disc drive 44 1 . 
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Although the invention has been described with a certain degree of 
particularity, it should be recognized that elements thereof may be altered by 
persons skilled in the art without departing from the spirit and scope of the 
invention. For example, although the invention is described with a particular - 
5 emphasis on TAPI, the invention can be practiced using any telephonic software 
interface. Therefore, the invention is limited only by the following claims and 
their equivalents. 
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WHAT IS CLAIMED IS: 

1 . A method for transmitting information from an application program 
on a line device, said method comprising the steps of: 

receiving an object from said application program at an object- - 
5 oriented interface layer, 

causing, by said object-oriented interface layer, a telephony 
software interface to perform an operation corresponding to said object; 

receiving a message from said line device at said object-oriented 
interface layer; and 

10 forwarding said message from said object-oriented interface layer to 

said application program. 

2. A system for transmitting information from a first computer to a 
second computer, said system comprising: 

15 an application program for generating said information; 

a line device for transmitting said information from said first 
computer to said second computer, 

a telephony software interface for causing said line device to 
perform at least one operation corresponding to a command; and 
20 an object-oriented interface layer for receiving an object from said 

application program, generating said command, wherein said command 
corresponds to said object, receiving a message from said line device and 
forwarding said message to said application program. 

25 3. An article of manufacture comprising a computer usable medium 

having computer readable program code means embodied thereon for transmitting 
information from an application program on a line device, the computer readable 
code means in said article of manufacture comprising means for: 

receiving an object from said application program at an object- 

3 0 oriented interface layer; 
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causing, by said object-oriented interface layer, a telephony 
software interface to perform an operation corresponding to said object; 

receiving a message from said line device at said object-oriented 
interface layer; and - 
5 forwarding said message from said object-oriented interface layer to 

said application program. 
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